package com.xuenci.gulimall.order;

import org.springframework.amqp.rabbit.annotation.EnableRabbit;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
import org.springframework.context.annotation.EnableAspectJAutoProxy;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;

/**
 * 本地事务失效问题
 * 同一个对象内事务方法互调默认失效，原因  绕过了代开对象，事务使用代理对象来控制的
 * 解决：使用代理对象来调用事务方法
 *      1）、引入aop-strater;  spring-boot-stater-aop; 引入了aspect
 *      2）、@EnableTransactionManagement(proxyTargetClass = true)； 引入了aspectj动态代理功能。以后所有的动态代理都是aspectj
 *          对外暴露代理对象
 *      3）、本类互调调用对象
 *          OrderServiceImpl orderService = (OrderServiceImpl)AopContext.curentProxy();
 *          orderService.b();
 *          orderService.c();
 *
 * Seata控制分布式事务
 *  1）、每一个微服务先必须创建undo_log表
 *  2）、安装事务协调器：Seata_server ： https://github.com/seata/seata/releases
 *  3）、整合：
 *      1、导入依赖：spring-cloud-starter-alibaba-seata     seata-all 0.7.1
 *      2、解压并启动Seata-server    版本跟Seata-all的版本一致  在External Libraries里面找
 *          conf/registry.conf  注册中心相关的配置     修改registry type = "nacos"
 *          file.conf
 *      3、所有想要用到的分布式事务的微服务使用seata DataSourceProxy代理自己的数据源
 *      4、每个微服务必须导入
 *          registry.conf
 *          file.conf    vgroup_mapping.{application.name}-fascar-service-group = "default"
 *      5、启动测试分布式事务
 *      6、给分布式大事务的入口标注@GlobalTransactional
 *      7、每一个远程的小事务用 @Transactional
 *
 *
 */
//@EnableAspectJAutoProxy(exposeProxy = true)
@EnableFeignClients
@EnableRedisHttpSession
@EnableDiscoveryClient
@EnableRabbit
@SpringBootApplication
public class GulimallOrderApplication {

    public static void main(String[] args) {
        SpringApplication.run(GulimallOrderApplication.class, args);
    }

}
